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REDUCCION DE LA VULNERABILIDAD ANTE ERRORES DE 
SOFTWARE DE DATOS ALMACENADOS 

5 Antecedentes 

1. Campo 

La presente descripcion pertenece al campo del 
procesamiento o tratamiento de datos y, mas particularmente, al campo 
de la mitigacion de los errores en aparatos de tratamiento de datos. 

10 

2. Descripcion de la tecnica relacionada 

A medida que las mejoras en las tecnologias de fabricacion 
de circuitos integrados continuan proporcionando dimensiones mas 
pequenas y tensiones de funcionamiento mas bajas en los 

15 microprocesadores y otros aparatos de tratamiento de datos, los 
fabricantes y los usuarios de estos dispositivos se estan viendo cada vez 
mas afectados por el fenomeno de los errores de software o 
programacion. Los errores de software aparecen cuando particulas alfa y 
neutrones de altas energias chocan contra circuitos integrados y alteran 

20 las cargas almacenadas en los nodos de los circuitos. Si la alteracion de 
la carga es lo suficientemente grande, la tension en un nodo puede 
resultar modificada de un nivel que representa un estado logico a un 
nivel que representa un estado logico diferente, en cuyo caso la 
informacion almacenada en ese nodo queda alterada. En general, los 

25 indices de produccion de errores de software se incrementan conforme se 
reducen las dimensiones de los circuitos, debido a que la probabilidad de 
que una particula incidente choque con un nodo de tension se incrementa 
cuando aumenta la densidad del circuito. De la misma manera, a medida 
que se reducen las tensiones de funcionamiento, la diferencia entre los 

30 niveles de tension que representan estados logicos distintos disminuye, 
de tal manera que se necesita menos energia para alterar los estados 
logicos en los nodos de los circuitos, y se producen mas errores de 
software. 

La obstruccion o bloqueo de las particulas que provocan los 
35 errores de software resulta extremadamente dificil, de modo que los 
aparatos de tratamiento de datos incluyen a menudo soporte para codigos 



de correccion de errores ("ECC" -"error correcting codes"), paridad u 
otras tecnicas para detectar y, en ocasiones, corregir, los errores de 
software. Dependiendo de la tecnica particular que se utilice y de la 
extension en la que se lleve a la practica, el coste de este soporte puede 
consistir en dispositivos fisicos o hardware anadido y un rendimiento 
reducido, y el nivel de deteccion o capacidad de correccion puede estar 
limitada a errores de uno o dos bits. Sedan deseables tecnicas 
alternativas de mitigacion de errores que pudieran ofrecer a los 
disenadores de aparatos de tratamiento de datos opciones de diferentes 
costes y capacidades. 

Breve descripcion de los dibujos 
La presente invencion se ilustra a modo de ejemplo y de 
manera no limitativa en las figuras que se^acompanan. 

La Figura 1 ilustra una realizacion de la presente invencion 
en un procesador que tiene logica de almacenamiento y logica de 
determinacion de valores estrechos. 

La Figura 2 ilustra una realizacion de la presente invencion 
en un procesador que tiene logica de almacenamiento y logica de 
determinacion de cero bytes. 

La Figura 3 ilustra una realizacion de la presente invencion 
en un procesador que tiene logica de almacenamiento redundante y 
logica de determinacion de valores estrechos. 

La Figura 4 ilustra una realizacion de la presente invencion 
en un procesador que tiene logica de almacenamiento redundante y 
logica de determinacion de cero bytes. 

La Figura 5 ilustra otra realizacion de la presente invencion 
en un metodo para reducir la vulnerabilidad ante errores de software de 
datos almacenados que representan un valor estrecho. 

La Figura 6 ilustra una realizacion de la presente invencion 
en un metodo para detectar y corregir errores de software en datos 
almacenados que representan un valor estrecho. 

La Figura 7 ilustra una realizacion de la presente invencion 
en un metodo para reducir la vulnerabilidad ante errores de software de 
datos almacenados que incluyen una porcion reemplazable. 

La Figura 8 ilustra una realizacion de la presente invencion 



en un sistema de tratamiento de datos. 



Descripcion detallada 
En lo que sigue se describen realizaciones de aparatos y de 
metodos para reducir la vulnerabilidad ante errores de software de datos 
almacenados. En la siguiente descripcion pueden establecerse numerosos 
detalles especificos, tales como configuraciones logicas de 
almacenamiento, con el fin de proporcionar una comprension mas 
exhaustiva de la presente invenci6n. Se apreciara, sin embargo, por parte 
de un experto de la tecnica, que la invencion puede llevarse a la practica 
sin tales detalles especificos. Adicionalmente, no se han descrito en 
detalle algunas estructuras, circuitos, tecnicas y similares bien 
conocidos, al objeto de evitar oscurecer innecesariamente la presente 
» invencion. 

Ciertas realizaciones de la presente invencion pueden 
reducir la vulnerabilidad ante errores de software o programacion de 
datos almacenados, al beneficiarse del hecho de que muchos de los 
valores de datos que se utilizan en los aparatos de tratamiento de datos 
son mas estrechos, en terminos del numero de bits, que los registros, 
colas, registros de almacenamiento intermedio, dispositivos biestables de 
retencion de datos, u otra logica de almacenamiento que se proporcionan 
para almacenarlos. En consecuencia, estos valores estrechos se prolongan 
o extienden a menudo mediante signos o se ensanchan de otra manera, lo 
que da lugar al almacenamiento de datos en posiciones de bit que no son 
25 requeridas para su correcta ejecucion por parte del aparato de 
tratamiento de datos. Ciertas realizaciones de la presente invencion 
contemplan la practica de ignorar los errores de software en los datos 
contenidos en estas posiciones de bit cuando los datos no se requieren, y 
utilizar estas posiciones de bit para almacenar de forma redundante otros 
datos con el fin de hacer que esos datos sean menos vulnerables a los 
errores de software. Ciertas realizaciones de la presente invencion 
pueden utilizarse solas o en combinacion con otras tecnicas de deteccion, 
correccion o mitigacion de errores. 

La Figura 1 ilustra una realizacion de la presente invencion 

35 en un procesador 100. 

El procesador 100 puede ser cualquiera de entre una 
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variedad de tipos diferentes de procesadores, tales como un procesador 
de la Familia de Procesadores Pentium®, de la Familia de Procesadores 
Itanium® o de otra familia de procesadores de la Intel Corporation, o 
bien cualquier otro procesador de proposito general u otro de otra 

5 compania. Si bien la Figura 1 ilustra la invencion incorporada en un 
procesador, la invencion puede, alternativamente, llevarse a la practica 
en cualquier otro tipo de componente o aparato de tratamiento de datos, 
tal como un conjunto o instalacion de chips, cualquier tipo de memoria, 
incluyendo memoria del sistema principal o memoria de disco, un bus o 

10 interconexion, o cualquier otro componente que almacene o transmita 
informacion. 

El procesador 100 incluye logica de almacenamiento 110, 
que puede ser cualquier logica o circuito destinado a almacenar datos, tal 
cotno un registro, una instruccion u otro tipo de cola o registro de 

15 almacenamiento intermedin, un dato u otro tipo de dispositivo cache, un 
dispositivo biestable de retencion de datos o de otro tipo, o bien 
cualquier otra estructura de memoria, en el cual los datos pueden ser 
cualquier tipo de informacion, incluyendo instrucciones, representadas 
por digitos binarios ("bits") o de cualquier otra forma. La logica de 

20 almacenamiento 110 puede estar construida a partir de cualquier tipo de 
elemento de almacenamiento, tal como dispositivos biestables o circuitos 
basculadores. En esta descripcion, pueden utilizarse "0" (o "cero") y "1" 
(o "uno") para describir valores de bit, de tal manera que el primero 
puede ser cualquier tension u otro nivel que represente un "cero" logico 

25 o valor de "desconexion" o inactivo, y el ultimo puede ser cualquier 
nivel tal, que represente un "uno" logico o valor de "conexion" o activo. 
En el caso de que todos los bits de un byte, palabra o cualquier otra 
cantidad de datos presenten un valor "0", esa cantidad de datos puede ser 
descrita como dotada de un valor cero. 

30 En la realizacion de la Figura 1, la logica de almacenamiento 

110 se ha disenado para almacenar una palabra de datos (una 
"dataword") en la que una palabra consiste en cuatro bytes y un byte esta 
formado por ocho bits. Sin embargo, en otras realizaciones, la logica de 
almacenamiento correspondiente puede haberse disenado para almacenar 

35 cualquier otra cantidad de datos o tamano de un valor de dato, y una 
palabra de datos puede consistir en cualquier otro numero de bytes o de 



bits. La logica de almacenamiento 110 incluye 16gica de almacenamiento 
de byte cero 120, logica de almacenamiento de byte 0 120, logica de 
almacenamiento de byte 1 121, logica de almacenamiento de byte 2 122, 
logica de almacenamiento de byte 3 123, y logica de almacenamiento de 

5 indicador 130. Cada una de las logicas de almacenamiento de byte 0, 
byte 1, byte 2 y byte 3, 120, 121, 122 y 123, respectivamente, esta 
destinada a almacenar una porcion, un byte en esta realizacion, de una 
palabra de datos. En esta realizacion, la logica de almacenamiento de 
byte 0 120 esta destinada a almacenar el bit de orden inferior de una 

10 palabra de datos, la logica de almacenamiento de byte 1 121 tiene el 
proposito de almacenar el byte del segundo orden mas bajo, la logica de 
almacenamiento de byte 2 122 esta destinada a almacenar el byte del 
tercer orden mas bajo, y la logica de almacenamiento de byte 3 123 tiene 
el fir\ de almacenar el byte de orden mas alto. 

15 El procesador 100 incluye asimismo logica de determinacion 

140. La logica de determinacion 140 puede ser cualquier logica o 
circuito que determine una condicion de una palabra de datos para que 
esta se almacene en la logica de almacenamiento 110. En esta 
realizacion, la condicion es que la palabra de datos sea un valor 

20 estrecho, donde un valor estrecho es un byte de datos prolongado con 
signos. Por ejemplo, la palabra de datos "00000000 00000000 00000000 
01010101" es una version prolongada con signos del byte "01010101", 
en la que se utiliza el "0" en el bit mas significativo del byte para 
indicar que el valor del byte es un numero positivo. Como otro ejemplo, 

25 "11111111 11111111 11111111 11010101" es una version prologada con 
signos de "11010101", en la que se utiliza "1" en el bit mas significativo 
del byte para indicar que el valor del byte es un numero negativo. Es 
posible utilizar cualquier forma de codificacion, tal como la de 
complemento de dos o la de complemento de uno, dentro del ambito de la 

30 presente invencion. 

En la realizacion de la Figura 1, la logica de determinacion 
140 incluye un comparador de byte 1 141, un comparador de byte 2 142 y 
un comparador de byte 3 143. Cada uno de los comparadores 141, 142 y 
143 puede incluir una puerta O exclusiva por cada bit, a fin de 

35 determinar si cada bit del respectivo byte es igual al bit de orden mas 
alto del byte 0 de la palabra de datos. Alternativamente, la logica de 
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determinacion 140 puede incluir detectores de cero de cabeza y/o de uno 
de cabeza, implementados en configuracion de familia logica o de 
familia de circuitos, dinamica o de cualquier otro tipo, o bien puede 
realizarse en la practica utilizando cualquier otra solucion para 
5 determinar la existencia de una condicion. La logica de determinacion 
140 genera un resultado para indicar si la condicion se da, por ejemplo, 
en esta realizacion, si la palabra de datos que ha de ser almacenada en la 
logica de almacenamiento 110 es un valor estrecho, es decir, si cada bit 
del byte 1, del byte 2 y del byte 3 es igual al bit de orden mas alto del 
10 byte 0. 

La logica 130 de almacenamiento de indicador esta destinada 
a almacenar un resultado generado por la logica de determinacion 140, 
en esta realizacion, un unico bit (un "bit indicador") destinado a indicar 
si la palabra de datos correspondiente es un valor estrecho^ 

15 Una vez que se han almacenado una palabra de datos y el bit 

indicador correspondiente en la logica de almacenamiento 110, podria 
producirse un error de software en uno o mas de los bits de la logica de 
almacenamiento 110 como consecuencia de la colision de una particula u 
otro suceso o sucesos. Por lo tanto, el procesador 100 incluye tambien 

20 logica de seleccion 150 destinada a seleccionar, bien el contenido de los 
bytes de orden superior de la logica de almacenamiento 110 6 bien 
valores de reemplazo para estos bytes. La seleccion se basa en el 
contenido de la logica 130 de almacenamiento de indicador. Si el 
contenido de la logica 130 de almacenamiento de indicador indica que la 

25 palabra de datos almacenada en la logica de almacenamiento 110 es un 
valor estrecho, entonces, cuando se leen los datos o se proporcionan de 
otra manera desde la logica de almacenamiento 110, tan solo se lee 
realmente el contenido de la logica de almacenamiento de byte 0 120. 
Los valores proporcionados para los bytes de orden superior se obtienen 

30 mediante la extension o prolongacion con signos de los datos leidos de la 
logica de almacenamiento de byte 0 120. De esta forma, pueden ser 
ignorados uno o mas errores de software de los bytes de orden superior 
de un valor estrecho. 

La logica de seleccion 150 puede incluir multiplexadores 

35 controlados por el contenido de la logica 130 de almacenamiento de 
indicador, por ejemplo, un multiplexador por bit, a fin de proporcionar, 
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bien el valor del bit almacenado en el correspondiente bit de las logicas 
de almacenamiento de byte 1, de byte 2 6 de byte 3, 121, 122 6 123, 
respectivamente, o bien el valor del bit almacenado en la posicion de 
orden mas alto de la logica de almacenamiento de byte 0 120. Ademas, o 

5 alternativamente, la logica de seleccion 150 puede incluir 
multiplexadores destinados a proporcionar, ya sea el primero segun se ha 
descrito en lo anterior, ya sea un valor logico instalado permanentemente 
en hardware de cero o uno, como puede ser de utilidad en una de las 
realizaciones alternativas que se describe mas adelante. 

10 Son posibles diversas alternativas de la invencion. Por 

ejemplo, la logica de determinacion 140 puede determinar si el valor de 

cada uno de los bytes de orden superior es cero, la logica 130 de 

almacenamiento de indicador puede incluir un linico bit para indicar que 

el valor de cada uno de los bytes de orden superior es cero, y la logica de 

15 seleccion 150 puede proporcionar un valor de reemplazo de cero para 

* 

cada uno de los bytes de orden superior. O bien la logica de 
determinacion 140 puede determinar si el valor de cada bit de cada uno 
de los bytes de orden superior es uno, la logica 130 de almacenamiento 
de indicador puede incluir un unico bit destinado a indicar que el valor 

20 de cada bit de cada uno de los bytes de orden superior es uno, y la logica 
de seleccion 150 puede proporcionar un valor de reemplazo de uno para 
cada bit de cada uno de los bytes de orden superior. O bien, la logica de 
determinacion 140 puede determinar ambas posibilidades anteriores, la 
logica 130 de almacenamiento de indicador puede incluir un bit para 

25 indicar que el valor de cada uno de los bytes de orden superior es cero, y 
otro bit para indicar que el valor de todos los bits de cada uno de los 
bytes de orden superior es uno, y la logica de seleccion 150 puede 
proporcionar el valor de reemplazo apropiado. 

En la Figura 2 se ilustra otra realizacion alternativa. La 

30 Figura 2 muestra un procesador 200 que incluye logica de 
almacenamiento 210. De nuevo, en esta realizacion y en cualquier otra 
realizacion que se describa en lo que sigue, puede utilizarse cualquier 
tipo de procesador y de logica de almacenamiento, y la logica de 
almacenamiento puede emplearse para cualquier funcion dentro del 

35 procesador. 

La logica de almacenamiento 210 incluye una logica de 
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almacenamiento de byte 0 220, una logica de almacenamiento de byte 1 
221, una logica de almacenamiento de byte 1 222, una logica de 
almacenamiento de byte 3 223, una logica de almacenamiento de 
indicador de byte 0 230, una logica de almacenamiento de indicador de 

5 byte 1 231, una logica de almacenamiento de indicador de byte 2 232 y 
una logica de almacenamiento de indicador de byte 3 233. 

El procesador 200 incluye tambien una logica de 
determinacion de byte 0 240, una logica de determinacion de byte 1 241, 
una logica de determinacion de byte 2 242 y una logica de determinacion 

10 de byte 3 243, cada una de las cuales determina si el correspondiente 
byte de la palabra de datos que se ha de almacenar en la logica de 
almacenamiento 210 es igual a cero. Si es asi, se establece el bit 
indicador correspondiente en la logica de almacenamiento de indicador 
de byte 0 230, en, la logica de almacenamiento de indicador de \?yte 1 

15 231, en la logica de almacenamiento de indicador de byte 2 232, 6 en la 
logica de almacenamiento de indicador de byte 3 233. 

El procesador 200 incluye tambien una logica de seleccion 
de byte 0 250, una logica de seleccion de byte 1 251, una logica de 
seleccion de byte 2 252 y una logica de seleccion de byte 3 253. Cada 

20 una de ellas esta destinada a seleccionar, bien el contenido del 
correspondiente byte de la logica de almacenamiento 210, 6 bien valores 
de reemplazo para estos bytes. La seleccion esta basada en el contenido 
de la correspondiente logica de almacenamiento de indicador 230, 231, 
232 6 233. El valor de reemplazo es, en esta realizacion, un byte cero. 

25 En otra realizacion, en la que la logica de determinacion ha de 
determinar si cada bit de un byte de la palabra de datos que se ha de 
almacenar es igual a uno, el valor de reemplazo puede ser un valor 
"11111111". 

En la realizacion de la Figura 2 puede reemplazarse 
30 cualquier byte, incluyendo el byte de orden mas bajo, o cualquier 
combinacion de bytes. 

En la Figura 3 se muestra otra realizacion de la presente 
invencion. La Figura 3 incluye un procesador 300, que incluye logica de 
almacenamiento 310, la cual incluye una logica de almacenamiento de 
35 byte 0 320, una logica de almacenamiento de byte 1 321, una logica de 
almacenamiento de byte 2 322, una logica de almacenamiento de byte 3 



323 y una logica 330 de almacenamiento de indicador. 

El procesador 300 incluye tambien logica de determinacion 
340, que determina si la palabra de datos que se ha de almacenar es un 
valor estrecho, como se ha descrito anteriormente. Si la logica de 
5 determinacion 340 determina que la palabra de datos es un valor 
estrecho, entonces se establece un bit indicador en la logica 330 de 
almacenamiento de indicador. 

El procesador 300 incluye tambien logica de seleccion 350, 

la cual incluye logicas de seleccion 351, 352 y 353. La logica de 

10 seleccion 351 selecciona, bien el byte 0 6 bien el byte 1 de la palabra de 

datos que se ha de almacenar en la logica de almacenamiento de byte 1 

321, la logica de seleccion 352 selecciona el byte 0 6 el byte 2 para su 

almacenamiento en la logica de almacenamiento de byte 2 322, y la 

logica de seleccion 353 selecciona, bien el byte 0 6 bien el byte 3 para 

15 su almacenamiento en la logica de almacenamiento de byte 3 323. En 

» 

cada caso, se almacena el byte 0 si la logica de determinacion 340 
determina que la palabra de datos que se ha de almacenar es un valor 
estrecho. En consecuencia, pueden almacenarse copias redundantes del 
byte 0 con el fin de hacer posible la deteccion y correccion de errores de 

20 software, tal y como se describe mas adelante. 

El procesador 300 incluye tambien logica de seleccion 360, 
la cual incluye logicas de seleccion 361, 362 y 363. La logica de 
seleccion 361 selecciona, bien el contenido de la logica de 
almacenamiento de byte 1 321, 6 bien un valor de reemplazo, la logica 

25 de seleccion 362 selecciona, bien el contenido de la logica de 
almacenamiento de byte 2 322, 6 bien un valor de reemplazo, y la logica 
de seleccion 363 selecciona, ya sea el contenido de la logica de 
almacenamiento de byte 3 323, ya sea un valor de reemplazo. Cada 
seleccion esta basada en el contenido de la logica 330 de 

30 almacenamiento de indicador, de tal manera que se selecciona el valor de 
reemplazo en el caso de que el bit indicador indique que la palabra de 
datos almacenada es un valor estrecho. El valor de reemplazo es, bien 
todo ceros si el bit de orden mas alto del byte de orden mas bajo es un 
cero, o bien todo unos, en el caso de que el bit de orden mas alto del 

35 byte de orden mas bajo sea un uno. De manera alternativa, puesto que el 
byte de orden mas bajo se repite en cada una de las otra posiciones de 
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byte, el valor de reemplazo para cada byte puede formarse copiando el 
bit de orden mas alto de cada byte en cada uno de los otros bits del byte 
correspondiente. 

En otras realizaciones, la logica de determinacion 340 puede 

5 determinar si la totalidad de los bits de los bytes de orden superior son 
cero, y los valores de reemplazo pueden ser todo ceros, o la logica de 
determinacion 340 puede determinar si todos los bits de los bytes de 
orden superior son uno, y los valores de reemplazo pueden ser todo unos, 
o bien la logica de determinacion 340 puede determinar si se da una de 

10 las dos condiciones, y pueden estar disponibles ambos valores de 
reemplazo. 

El procesador 300 incluye asimismo logica de error 370, la 
cual puede llevar a cabo una deteccion de errores o una correccion de 
errores. La logica de error t 370 puede realizar una deteccion de errores 

15 comparando unos con otros cada uno de los bytes leidos de la logica de 
almacenamiento 310, de cualquier numero de formas, tal como por la 
comparacion de cada uno de los bytes de orden superior con el byte de 
orden mas bajo, la comparacion de cada byte con cada uno de los otros 
bytes, o de cualquier otra manera. Si cualquiera de tales comparaciones 

20 determina que uno cualquiera de los bytes no coincide con algun otro 
byte, entonces la logica de error 370 indica que hay un error en los datos 
leidos de la logica de almacenamiento 310, utilizando cualquier solucion 
conocida, tal como generando un fallo o excepcion. 

La comparacion puede llevarse a cabo unicamente cuando el 

25 contenido de la logica 330 de almacenamiento de indicador indica que se 
ha almacenado un valor estrecho, o bien puede realizarse con 
independencia del contenido de la logica 330 de almacenamiento de 
indicador, si bien el resultado de la comparacion es ignorado a menos 
que la logica 330 de almacenamiento de indicador indique que se ha 

30 almacenado un valor estrecho. 

El procesador 300 incluye tambien un camino o recorrido de 
datos 380 para leer los datos y extraerlos de la logica de almacenamiento 
310 hasta un destino. 

La logica de error 370 puede llevar a cabo la correccion de 

35 los errores realizando las comparaciones segiin se ha descrito en lo 
anterior, e ignorando entonces, si se encuentra alguna falta de 
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coincidencia, los datos procedentes del byte que es diferente de los otros 
bytes. Por ejemplo, si los datos procedentes de la logica de 
almacenamiento de byte 0 320, de la logica de almacenamiento de byte 1 
321 y de la logica de almacenamiento de byte 2 322 son todos el mismo, 

5 pero los datos procedentes de la logica de almacenamiento de byte 3 323 
son diferentes, entonces los datos procedentes de la logica de 
almacenamiento de byte 3 323 pueden ser ignorados y los datos 
procedentes de la logica de almacenamiento de byte 0 320 pueden 
extraerse por lectura hasta el recorrido de datos 380, como el valor del 

10 byte 0 de la palabra de datos almacenada. O bien, si los datos 
procedentes de la logica de almacenamiento de byte 1 321, de la logica 
de almacenamiento de byte 2 322 y de la logica de almacenamiento de 
byte 3 323 son todos el mismo, pero los datos procedentes de la logica 
de almacenamiento de byte 0 ,320 son diferentes, entonces los datos 

15 procedentes de la logica de almacenamiento de byte 0 320 pueden ser 
ignorados y los datos procedentes de la logica de almacenamiento de 
byte 1 pueden extraerse por lectura hasta el recorrido de datos 380, como 
el valor del byte 0 de la palabra de datos almacenada. 

Notese que las comparaciones que se han descrito en lo 

20 anterior pueden detectar errores multiples. Por ejemplo, los datos 
procedentes de la logica de almacenamiento de byte 0 320, de la logica 
de almacenamiento de byte 1 321 y de la logica de almacenamiento de 
byte 2 322 pueden ser todos el mismo, pero los datos procedentes de la 
logica de almacenamiento de byte 3 323 pueden diferir de esos datos en 

25 dos posiciones de bit, lo que se interpretara como un error de doble bit. 
O bien, los datos procedentes de la logica de almacenamiento de byte 0 
320 y de la logica de almacenamiento de byte 1 321 pueden ser los 
mismos, y los datos procedentes de la logica de almacenamiento de byte 
2 322 pueden diferir de esos datos en una posicion de bit, y los datos 

30 procedentes de la logica de almacenamiento de byte 3 323 pueden diferir 
en una posicion de bit diferente, lo cual se interpretara como un error de 
doble bit. 

De acuerdo con ello, la tabla que se proporciona a 
continuacion indica las posibles acciones que pueden adoptarse 
35 dependiendo del numero y posicion de los errores detectados por la 
logica de error 370. Los valores de las cuatro primeras columnas 
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representan el numero de errores encontrados en el byte indicado en el 
encabezamiento de la columna. Como puede observarse en la tabla, 
puede ser deseable el uso de realizaciones de la presente invencion con 
el fin de hacer posible la deteccion y correccion de errores de multiples 
bits. Otras tablas o acciones son posibles en otras realizaciones. 



Byte 0 


Byte 1 


Byte 2 


Byte 3 


Accion 


0 


0 


0 


1 


corregir error 


0 


0 


0 


2 


corregir error 


0 


0 


1 


1 


corregir error si los bytes 2 y 3 son diferentes, 
detectar error si los bytes 2 y 3 son el mismo 


0 


0 


0 


3 


corregir error 


0 


0 


1 


2 


corregir error 


0 


1 


1 


1 


detectar error si los bytes 1, 2 y 3 son diferentes, 
fallo si los bytes 1, 2 y 3 son el mismo 


0 


0 


0 


4 


corregir error 


0 


0 


1 


3 


corregir error 


0 


0 


2 


2 


corregir error si los bytes 2 y 3 son diferentes, 
detectar error si los bytes 2 y 3 son el mismo 


0 


1 


1 


2 


detectar error 


1 


1 


1 


1 


detectar error si los bytes 0, 1, 2, y 3 son diferentes, 
fallo si los bytes 0, 1, 2 y 3 son el mismo 



En la Figura 4 se ilustra aun otra realizacion de la presente 
invencion. La Figura 4 incluye un procesador 400, que incluye logica de 
almacenamiento 410, la cual incluye una logica de almacenamiento de 
byte 0 420, una logica de almacenamiento de byte 1 421, una logica de 
almacenamiento de byte 2 422, una logica de almacenamiento de byte 3 
423, una logica 431 de almacenamiento de indicador, una logica 432 de 
almacenamiento de indicador y una logica 433 de almacenamiento de 
indicador. 

El procesador 400 incluye tambien logicas de determinacion 
440, 441, 442 y 443, las cuales determinan si el byte de la palabra de 
datos que se ha de almacenar, respectivamente, en la logica de 
almacenamiento de byte 0 420, en la logica de almacenamiento de byte 1 
421, en la logica de almacenamiento de byte 2 422 y en la logica de 
almacenamiento de byte 3 423 es un byte cero. Si las logicas de 
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determinacion 440, 441, 442 6 443 determinan que el byte 
correspondiente es un byte cero, entonces se ajusta un bit indicador, 
respectivamente, en las logicas de almacenamiento de indicador 430, 
431, 432 6 433. 

5 El procesador 400 incluye asimismo logicas de seleccion 

450, 451, 452 y 453. La logica de seleccion 450 selecciona el byte 0 de 
la palabra de datos para almacenarlo en la logica de almacenamiento de 
byte 0 420 si la logica de determinacion 440 determina que el byte 0 no 
es un byte cero o nulo, o bien el byte 1 si el byte 0 es un byte cero o 

10 nulo pero el byte 1 no lo es. La logica de seleccion 451 selecciona el 
byte 1 de la palabra de datos para almacenarlo en la logica de 
almacenamiento de byte 1 421 si la logica de determinacion 441 
determina que el byte 1 no es un byte cero o nulo, o bien el byte 0 si el 
byte 1 es un byte cero o nulo perb el byte 0 no lo es. De esta forma, la 

15 logica de almacenamiento de byte 0 420 y la logica de almacenamiento 
de bit 1 421 se agrupan para proporcionar un almacenamiento redundante 
una para la otra. 

Analogamente, la logica de seleccion 452 selecciona el byte 
2 de la palabra de datos para almacenarlo en la logica de almacenamiento 

20 de byte 2 422 si la logica de determinacion 442 determina que el byte 2 
no es un byte cero o nulo, o bien el byte 3 si el byte 2 es un byte nulo 
pero el byte 3 no lo es. La logica de seleccion 453 selecciona el byte 3 
de la palabra de datos para almacenarlo en la logica de almacenamiento 
de byte 3 423 si la logica de determinacion 443 determina que el byte 3 

25 no es un byte nulo, o bien el byte 2 si el byte 3 es un byte cero o nulo 
pero el byte 2 no lo es. 

El procesador 400 incluye tambien logicas de seleccion 460, 
461, 462 y 463. La logica de seleccion 460 selecciona un valor de 
reemplazo de byte nulo para que sea leido de la logica de 

30 almacenamiento de byte 0 420 en el caso de que la logica 430 de 
almacenamiento de indicador indique que se encuentra almacenado un 
byte cero o nulo en la logica de almacenamiento de byte 0 420; en caso 
contrario, el contenido de la logica de almacenamiento de byte 0 420 se 
extrae por lectura. La logica de seleccion 461 selecciona un valor de 

35 reemplazo de byte nulo para que sea leido de la logica de 
almacenamiento de byte 1 421 en el caso de que la logica 431 de 



14 

almacenamiento de indicador indique que se encuentra almacenado un 
byte nulo en la logica de almacenamiento de byte 1 421; de otro modo, el 
contenido de la logica de almacenamiento de byte 1 421 se extrae por 
lectura. La logica de seleccion 462 selecciona un valor de reemplazo de 

5 byte nulo para que sea leido de la logica de almacenamiento de byte 2 
422 en el caso de que la logica 432 de almacenamiento de indicador 
indique que se encuentra almacenado un byte nulo en la logica de 
almacenamiento de byte 2 422; en caso contrario, el contenido de la 
logica de almacenamiento de byte 2 422 se extrae por lectura. La logica 

10 de seleccion 463 selecciona un valor de reemplazo de byte nulo para que 
sea leido de la logica de almacenamiento de byte 3 423 en el caso de que 
la logica 433 de almacenamiento de indicador indique que se encuentra 
almacenado un byte cero o nulo en la logica de almacenamiento de byte 3 
423; en caso contrario, el contenido de la logica de almacenamiento de 

15 byte 3 423 se extrae por lectura. 

En otras realizaciones, las logicas de determinacion 440, 
441, 442 y 443 pueden determinar, de manera adicional o en su lugar, si 
todos los bits de los bytes de orden superior son unos, y los valores de 
reemplazo pueden ser todos unos. 

20 El procesador 400 incluye tambien una logica de error 470 y 

una logica de error 472. La logica de error 470 puede llevar a cabo la 
deteccion de errores comparando el contenido de la logica de 
almacenamiento de bit 0 420 con el contenido de la logica de 
almacenamiento de bit 1 421, y, si estos no coinciden, indicando que 

25 existe un error en los datos leidos de la logica de almacenamiento 410. 
La logica de error 472 puede llevar a cabo la deteccion de errores 
comparando el contenido de la logica de almacenamiento de bit 2 422 
con el contenido de la logica de almacenamiento de bit 3 423, y, si estos 
no coinciden, indicando que existe un error en los datos leidos de la 

30 logica de almacenamiento 410. 

La primera comparacion puede llevarse a cabo unicamente 
cuando el contenido de la logica 430 6 431 de almacenamiento de 
indicador indica que existe un valor redundante almacenado (es decir, 
que se detecto un byte cero o nulo), y la segunda comparacion puede 

35 realizarse tan solo cuando el contenido de la logica 432 6 433 de 
almacenamiento de indicador indica que existe un valor redundante 
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almacenado. Alternativamente, las comparaciones pueden llevarse a cabo 
independientemente de los contenidos de las logicas 430, 431, 432 y 433 
de almacenamiento de indicador, si bien los resultados de las 
comparaciones se ignoran a menos que la correspondiente logica de 
almacenamiento de indicador indique que se ha almacenado un valor 
redundante. 

Otras realizaciones pueden procurar las diferentes 
agrupaciones de bytes. Por ejemplo, el byte 0 y el byte 2 pueden 
agruparse uno con otro, y el byte 1 y el byte 3 pueden agruparse entre si. 
O bien, es posible agrupar entre si mas de dos bytes de almacenamiento 
logico, de manera que pueda posibilitarse la correccion de los errores. 

Cualquiera de las realizaciones anteriores, o bien 
cualesquiera otras realizaciones de la presente invencion, pueden dividir 
la logica de almacenamiento de las palabras en logica de almacenamiento 
de sub-palabras, de un tamano distinto de un byte. La eleccion del 
tamano de las sub-palabras puede depender del tamano tipico de los 
valores estrechos o nulos en un procesador dado, e implica compromisos 
entre el numero de valores estrechos o nulos detectables y el numero de 
bits protegidos o disponibles para redundancia cuando es detectado un 
valor estrecho o nulo. 

Tambien, ademas de la definicion de un valor estrecho 
proporcionada anteriormente, o en lugar de la misma, un valor estrecho 
puede ser cualquier palabra de datos que incluya un numero cualquiera 
de bits cuyos valores no se requieren para la ejecucion o el estado de la 
arquitectura correctos. Se hace referencia a la porcion de un valor 
estrecho que se requiere, como la porcion requerida del valor estrecho. 

Por otra parte, los bits indicadores de valor estrecho o nulo, 
tal y como se han descrito anteriormente, son en si mismos vulnerables a 
los errores de software y, por tanto, puede ser deseable protegerlos con 
ECC o paridad. Sin embargo, en ciertas realizaciones en las que los bytes 
susceptibles de ser ignorados no se utilizan para el almacenamiento 
redundante, un error en uno de tales bits no pondra en peligro el correcto 
estado de la arquitectura cuando el error haga cambiar el bit desde la 
situacion en que indica que los bytes son susceptibles de ignorarse, 
debido a que, en ese caso, los bytes seran leidos como si no existiese 
dicho bit. 
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La Figura 5 ilustra una realizacion de la presente invencion 
por lo que respecta al metodo 500 para reducir la vulnerabilidad de los 
datos almacenados ante errores de software o programacion. En la caja 
510 se verifica una palabra de datos que se ha de almacenar en un 
procesador, al objeto de determinar si es un valor estrecho. En caso de 
ser asi, se establece entonces, en la caja 520, un indicador de valor 
estrecho. La palabra de datos se almacena en la caja 530. En la caja 540, 
el indicador de valor estrecho se lee para determinar si la palabra de 
datos que se ha de leer del almacenamiento es un valor estrecho. Si no es 
asi, entonces se extrae por lectura toda la palabra de datos en la caja 
550. Si es asi, entonces se extrae por lectura el byte de orden mas bajo 
de la palabra de datos en la caja 560, y, en la caja 570, se extiende o 
prolonga con signos el byte de orden mas bajo con el fin de proporcionar 
los bytes de orden superior. „ 

La Figura 6 ilustra una realizacion de la presente invencion 
relativa al metodo 600 para reducir la vulnerabilidad de los datos 
almacenados ante los errores de software. En la caja 610 se comprueba 
una palabra de datos que se ha de almacenar en un procesador, a fin de 
determinar si se trata de un valor estrecho. Si es asi, se establece 
entonces, en la caja 620, un indicador de valor estrecho, a fin de indicar 
que la palabra de datos que se ha de almacenar es un valor estrecho, y, 
en la caja 621, se almacena el byte de orden mas bajo en cada posicion 
de almacenamiento para cada byte de la palabra de datos. Si no lo es, 
entonces, en la caja 630, se almacena cada byte de la palabra de datos en 
una posicion de almacenamiento correspondiente. En la caja 640, el 
indicador de valor estrecho se lee para determinar si la palabra de datos 
que se ha de leer del almacenamiento es un valor estrecho. Si no lo es, 
entonces, en la caja 650, se extrae por lectura toda la palabra de datos. 
Si lo es, entonces se lee, en la caja 660, el contenido de cada posicion de 
almacenamiento para la palabra de datos. En la caja 661 se comparan 
unos con otros los contenidos de cada posicion de almacenamiento. Si 
existe coincidencia, entonces, en la caja 670, el contenido de la posicion 
de almacenamiento de orden mas bajo se prolonga con signos para 
proporcionar la palabra de datos completa. Si no hay coincidencia, 
entonces, en la caja 671, se evalua el numero de discrepancias con el fin 
de determinar si el error es corregible. En caso de serlo, el error se 
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corrige entonces en la caja 672, al extraer por lectura el contenido de 
una posicion de almacenamiento que no contiene ningiin error, y 
prolongarla con signos. En caso de no serlo, entonces se indica la 
presencia de un error en la palabra de datos, en la caja 673. 

5 La Figura 7 ilustra una realizacion de la presente invencion 

relativa a un metodo 700 para reducir la vulnerabilidad de los datos 
almacenados ante errores de software. En la caja 710 se verifica una 
palabra de datos que se ha de almacenar en un procesador, a fin de 
determinar si incluye una porcion reemplazable, la cual puede ser un 

10 byte cero o nulo, una porcion en la que el valor de cada bit es igual al 
valor de todos los otros bits, o cualquier otra porcion que pueda ser 
reemplazada por un valor de reemplazo predeterminado. En la 
realizacion de la Figura 7, la palabra de datos incluye un byte de orden 
bajo y un, byte de orden alto, y el byte de orden alto se cpmprueba para 

15 determinar si es reemplazable. Si lo es, entonces se establece, en la caja 

720, un indicador destinado a indicar que la palabra de datos que se ha 
de almacenar incluye una porcion reemplazable, se almacena, en la caja 

721, el byte de orden bajo en una posicion de almacenamiento para el 
byte de orden bajo, y se almacena, en la caja 722, una copia redundante 

20 del byte de orden bajo, en una posicion de almacenamiento destinada al 
byte de orden alto. Si no lo es, entonces cada byte de la palabra de datos 
se almacena, en la caja 730, en la posicion de almacenamiento 
correspondiente. En la caja 740 se lee el indicador con el fin de 
determinar si la palabra de datos que se ha de leer del almacenamiento 

25 incluye una porcion reemplazable. Si no es asi, entonces se extrae por 
lectura la palabra de datos completa en la caja 750. Si es asi, entonces, 
en la caja 760, se lee el contenido de la posicion de memoria para el byte 
de orden bajo y, en la caja 761, se lee el contenido de la posicion de 
almacenamiento para el byte de orden alto. En la caja 762, el contenido 

30 de la posicion de almacenamiento para el bit de orden bajo se compara 
con el contenido de la posicion de almacenamiento para el bit de orden 
alto. Si existe coincidencia se proporciona entonces un valor de 
reemplazo, en la caja 770, para el byte de orden alto. Si no existe 
coincidencia, se indica entonces un error en la palabra de datos en la 

35 caja 771. 

Dentro del ambito de la presente invencion, los metodos que 
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se ilustran en las Figuras 5, 6 y 7 pueden llevarse a cabo en un orden 
diferente, en el que se han omitido las etapas que se ilustran y se han 
anadido etapas adicionales, o bien con una combinacion de etapas 
reordenadas, combinadas, omitidas o adicionales. Por ejemplo, en la 
5 Figura 6, las cajas 671 y 672 (que se encargan, respectivamente, de 
determinar si el error es corregible y de corregir el error) pueden 
omitirse si se implementa la deteccion de errores sin la correccion de los 
errores. 

La Figura 8 ilustra una realizacion de la presente invencion 

10 relativa a un sistema 800. El sistema 800 incluye un procesador 810 y 
una memoria de sistema 820. El procesador 810 puede ser cualquier 
procesador segun se ha descrito en lo anterior. La memoria de sistema 
820 puede ser cualquier tipo de memoria, tal como una memoria de 
acceso aleatorio basada en semiconductores, estatica o dinamica, una 

15 memoria de inscripcion por impulsos (tipo flash) o de solo lectura, 
basada en semiconductores, o bien una memoria de disco magnetico u 
optico. En el sistema 800, la memoria de sistema 820 puede ser la fuente 
de la palabra de datos que ha de ser almacenada en la logica de 
almacenamiento del procesador 810, 6 puede ser el destino de la palabra 

20 de datos que se ha de leer de la logica de almacenamiento en el 
procesador 810. 

El procesador 810 y la memoria de sistema 820 pueden 
conectarse el uno con la otra en cualquier disposicion, con cualquier 
combinacion de buses o conexiones directas o de punto a punto, y con la 

25 intermediacion de cualesquiera otros componentes. El sistema 800 puede 
incluir cualquier numero de buses, tales como un bus periferico, o de 
componentes, tales como dispositivos de entrada / salida, que no se 
muestran en la Figura 8. 

El procesador 100, 200, 300 6 400, 6 cualquier otro 

30 componente o porcion de un componente disenada de conformidad con 
una realizacion de la presente invencion, puede haberse disenado en 
varias etapas, desde su creacion hasta su fabricacion, pasando por su 
simulacion. Los datos que representan un diseno pueden representar el 
diseno de diversas maneras. En primer lugar, como resulta de utilidad en 

35 las simulaciones, el hardware o dispositivos fisicos pueden ser 
representados utilizando un lenguaje de descripcion de dispositivos 
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fisicos u otro lenguaje de descripcion funcional. De manera adicional o 
alternativa, es posible producir un modelo en el nivel de los circuitos, 
con puertas logicas y/o de transistor, en algunas etapas del 
procedimiento de diseno. Por otra parte, la mayoria de los disenos 

5 alcanzan, en alguna etapa, un nivel en el que pueden generarse modelos 
de los mismos con datos que representan la colocacion fisica de diversos 
dispositivos. En el caso de que se empleen tecnicas de fabricacion de 
semiconductores convencionales, los datos que representan el modelo de 
colocacion de los dispositivos pueden ser los datos que especifican la 

10 presencia o ausencia de diversas caracteristicas o formaciones en 

diferentes capas de mascara para las mascaras que se utilizan para 

producir un circuito integrado. 

En cualquier representacion del diseno, los datos pueden ser 

almacenados en cyalquier forma de un medio legible por la maquina. 

15 Medios legibles por la maquina pueden ser una onda optica o electrica 

* 

modulada o generada de otra manera para transmitir dicha informacion, 
una memoria o un medio de almacenamiento magnetico u optico, tal 
como un disco. Cualquiera de estos medios puede "portar" o "indicar" el 
diseno u otra informacion utilizada en una realizacion de la presente 

20 invencion, tal como las instrucciones en una rutina de recuperacion de 
errores. Cuando se transmite una onda portadora electrica que indica o 
porta la informacion hasta el grado en que se lleva a cabo el copiado, 
almacenamiento intermedio o retransmision de la senal electrica, se 
realiza una nueva copia. De esta forma, las acciones por parte de un 

25 proveedor de comunicacion o de un proveedor de red pueden ser acciones 
consistentes en realizar copias de un articulo, por ejemplo, una onda 
portadora, que incorporan tecnicas de la presente invencion. 

Se han descrito, pues, aparatos y metodos para reducir la 
vulnerabilidad ante errores de software de datos almacenados. Si bien se 

30 han descrito y mostrado en los dibujos que se acompanan ciertas 
realizaciones, ha de comprenderse que tales realizaciones son meramente 
ilustrativas, y no restrictivas, de la invencion en sentido amplio, y que 
esta invencion no esta limitada a las construcciones y disposiciones 
concretas que se han mostrado y descrito, ya que pueden darse, a traves 

35 del estudio de esta descripcion, diversas otras modificaciones para las 
personas con conocimientos ordinarios en la tecnica. En un sector de la 
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tecnologia como este, en el que el desarrollo es rapido y los avances 
adicionales no se preven facilmente, las realizaciones descritas pueden 
ser facilmente modificables en cuanto a su disposicion y detalle, 
facilitadas por los avances tecnologicos que lo permitan, sin apartarse de 
los principios de la presente descripcion ni del ambito de las 
reivindicaciones que se acompanan. 
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REIVINDICACIONES 

1. Un aparato que comprende: 

una primera logica de almacenamiento, destinada a 
almacenar una primera porcion de una palabra de datos; 

una segunda logica de almacenamiento, destinada a 
almacenar una segunda porcion de la palabra de datos; 

una logica de determinacion, destinada a determinar una 
condicion para la palabra de datos; 

una tercera logica de almacenamiento, destinada a almacenar 
un resultado generado por la logica de determinacion; y 

una logica de seleccion, destinada a seleccionar, basandose 
en el contenido de la tercera logica de almacenamiento, uno de entre el 
contenido de la segunda logica de almacenamiento y un valor de 
reemplazo que depende del contenido de un bit predeterminado de la 
primera logica de almacenamiento. 

2. El aparato de acuerdo con la reivindicacion 1, en el cual la 
primera porcion de la palabra de datos es la porcion menos significativa 
de la palabra de datos. 

3. El aparato de acuerdo con la reivindicacion 1, en el cual la 
condicion para la palabra de datos es que el valor de cada bit de la 
segunda porcion de la palabra de datos sea el mismo que el valor del bit 
mas significativo de la primera porcion de la palabra de datos. 

4. El aparato de acuerdo con la reivindicacion 1, en el cual 
cada bit del valor de reemplazo es igual al contenido del bit 
predeterminado de la primera logica de almacenamiento. 

5. El aparato de acuerdo con la reivindicacion 1, en el cual el 
bit predeterminado de la primera logica de almacenamiento esta 
destinado a almacenar el bit mas significativo de la primera porcion de la 
palabra de datos. 

6. El aparato de acuerdo con la reivindicacion 1, en el cual la 
primera logica de almacenamiento y la segunda logica de 
almacenamiento estan incluidas en uno de entre un registro, una cola de 
emision, una memoria cache de datos y un dispositivo biestable de 
retencion de datos. 

7. Un aparato que comprende: 
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una primera logica de almacenamiento, destinada a 
almacenar una primera porcion de una palabra de datos; 

una segunda logica de almacenamiento, destinada a 
almacenar una de entre la primera porcion de la palabra de datos y una 
5 segunda porcion de la palabra de datos; 

una logica de determinacion, destinada a determinar una 
condicion para la palabra de datos; 

una tercera logica de almacenamiento, destinada a almacenar 
un resultado generado por la logica de determinacion; 
10 una primera logica de seleccion, destinada a seleccionar, 

basandose en el resultado generado por la logica de determinacion, una 
de entre la primera porcion de la palabra de datos y la segunda porcion 
de la palabra de datos, para su almacenamiento en la segunda logica de 
almacenamiento; y 

15 una segunda logica de seleccion, destinada a seleccionar, 

basandose en el contenido de la tercera logica de almacenamiento, uno 
de entre el contenido de la segunda logica de almacenamiento y un valor 
de reemplazo. 

8. El aparato de acuerdo con la reivindicacion 7, en el cual la 
20 condicion para la palabra de datos es que el valor de cada bit de la 

segunda porcion de la palabra de datos sea el mismo que el valor de cada 
uno de los otros bits de la segunda porcion de la palabra de datos. 

9. El aparato de acuerdo con la reivindicacion 7, en el cual la 
condicion para la palabra de datos es que el valor de la segunda porcion 

25 de la palabra de datos sea cero. 

10. El aparato de acuerdo con la reivindicacion 7, en el cual el 
valor de reemplazo es cero. 

11. El aparato de acuerdo con la reivindicacion 7, en el cual la 
primera logica de almacenamiento y la segunda logica de 

30 almacenamiento estan incluidas en uno de entre un registro, una cola de 
emision, una memoria cache de datos y un dispositivo biestable de 
retencion de datos. 

12. El aparato de acuerdo con la reivindicacion 7, que 
comprende adicionalmente una logica de deteccion de errores destinada a 

35 comparar el contenido de la primera logica de almacenamiento y el de la 
segunda logica de almacenamiento. 
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13. El aparato de acuerdo con la reivindicacion 12, en el cual la 
logica de deteccion de errores ha de comparar el contenido de la primera 
logica de almacenamiento y el de la segunda logica de almacenamiento, 
en funcion del contenido de la tercera logica de almacenamiento. 

14. El aparato de acuerdo con la reivindicacion 7, que 
comprende adicionalmente: 

una cuarta logica de almacenamiento, destinada a almacenar 
una de entre la primera porcion de la palabra de datos y una tercera 
porcion de la palabra de datos; 

una tercera logica de seleccion, destinada a seleccionar, 
basandose en el resultado generado por la logica de determinacion, una 
de entre la primera porcion de la palabra de datos y la tercera porcion de 
la palabra de datos, a fin de almacenarla en la cuarta logica de 
almacenamiento; 

un camino o recorrido de datos, destinado a leer un valor 
almacenado de la primera logica de almacenamiento; y 

una logica de correccion de errores, destinada a comparar los 
contenidos de la primera logica de almacenamiento, de la segunda logica 
de almacenamiento y de la cuarta logica de almacenamiento, y, si el 
contenido de la segunda logica de almacenamiento es diferente del 
contenido de la primera logica de almacenamiento y el mismo que el 
contenido de la cuarta logica de almacenamiento, a proporcionar al 
recorrido de datos el contenido de la segunda logica de almacenamiento, 
en lugar del contenido de la primera logica de almacenamiento. 

15. Un metodo que comprende: 

determinar que una palabra de datos que ha de ser 
almacenada es un valor estrecho; 

almacenar la porcion requerida del valor estrecho; 

almacenar una indicacion de que el dato almacenado 
representa un valor estrecho; 

leer del almacenamiento la porcion requerida del valor 

estrecho; y 

proporcionar un valor de reemplazo para el resto del valor 

estrecho. 

16. El metodo de acuerdo con la reivindicacion 15, que 
comprende adicionalmente almacenar de forma redundante la porcion 
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requerida del valor estrecho. 

17. El metodo de acuerdo con la reivindicacion 16, que 
comprende adicionalmente: 

leer del almacenamiento la porcion requerida del valor 
5 estrecho almacenada de forma redundante; y 

comparar la porcion requerida del valor estrecho con la 
porcion del valor estrecho almacenada de forma redundante, a fin de 
comprobar la existencia de errores. 

18. El metodo de acuerdo con la reivindicacion 17, que 
10 comprende adicionalmente corregir un error en la porcion requerida del 

valor estrecho, al proporcionar, en lugar de la porcion requerida del 
valor estrecho procedente del almacenamiento, la porcion requerida del 
valor estrecho almacenada de forma redundante. 

19. Un metodo que comprende: * 

15 determinar que una palabra de datos que se ha de almacenar 

incluye una porcion irremplazable y una porcion reemplazable; 
almacenar la porcion irremplazable; 

almacenar una copia redundante de la porcion irremplazable; 

almacenar una indicacion de que los datos almacenados 
20 representan una palabra de datos que incluye una porcion reemplazable; 

leer la porcion irremplazable del almacenamiento; 

leer la copia redundante de la porcion irremplazable del 
almacenamiento; y 

comparar la porcion irremplazable procedente del 
25 almacenamiento con la copia redundante de la porcion irremplazable 
procedente del almacenamiento, a fin de comprobar la existencia de 
errores. 

20. El metodo de acuerdo con la reivindicacion 19, en el cual la 
porcion reemplazable tiene un valor de cero. 

30 21. Un sistema que comprende: 

una memoria; y 
un procesador, que incluye: 

una primera logica de almacenamiento, destinada a 
almacenar una primera porcion de una palabra de datos; 
35 una segunda logica de almacenamiento, destinada a 

almacenar una segunda porcion de la palabra de datos; 
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una logica de determinacion, destinada a determinar una 
condicion para la palabra de datos; 

una tercera logica de almacenamiento, destinada a almacenar 
un resultado generado por la logica de determinacion; y 

una logica de seleccion, destinada a seleccionar, basandose 
en el contenido de la tercera logica de almacenamiento, uno de entre el 
contenido de la segunda logica de almacenamiento y un valor de 
reemplazo que depende del contenido de un bit predeterminado de la 
primera logica de almacenamiento. 
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Resumen 

Se describen realizaciones de aparatos y metodos para 
5 reducir la vulnerabilidad ante errores de software o programacion de 
datos almacenados. En una realizacion, un aparato incluye logica de 
almacenamiento, logica de determinacion y logica de seleccion. La 
logica de determinacion esta destinada a determinar una condicion para 
una palabra de datos. La logica de almacenamiento incluye logica para 
10 almacenar una primera porcion de la palabra de datos, una segunda 
porcion de la palabra de datos, y un resultado generado por la logica de 
determinacion. La logica de seleccion tiene como proposito seleccionar, 
basandose en el contenido de la logica de almacenamiento para 
almacenar el resultado, bien el contenido de la logica de almacenamiento 
15 para almacenar la segunda porcion de la palabra de datos, o bien un valor 
de reemplazo. El valor de reemplazo depende del contenido de un bit 
predeterminado de la logica de almacenamiento para almacenar la 
primera porcion de la palabra de datos. 

20 
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